home *** CD-ROM | disk | FTP | other *** search
/ Graphics Plus / Graphics Plus.iso / general / procssng / alv.sun / alv.lha / src / invert.c < prev    next >
Encoding:
C/C++ Source or Header  |  1992-11-08  |  1.2 KB  |  56 lines

  1. #include <stdio.h>
  2. #include "defs.h"
  3.  
  4. har           *progname;
  5. har           *filename;
  6. ixrect        *pr;
  7.  
  8. #ifdef STANDALONE
  9. ain(argc, argv, envp)
  10. #else
  11. nvert_main(argc, argv, envp)
  12. #endif
  13.     int             argc;
  14.     char          **argv;
  15.     char          **envp;
  16. {
  17.     register int    i, j;
  18.     int             levels;
  19.     int         val;
  20.     colormap_t        colormap;
  21.  
  22.     progname = strsave(argv[0]);
  23.     parse_profile(&argc, argv, envp);
  24.  
  25.     while ((gc = getopt(argc, argv, " ")) != EOF)
  26.         switch (gc) {
  27.         case '?':
  28.             errflag++;
  29.             break;
  30.         }
  31.  
  32.     if (errflag)
  33.         error((char *) 0, "Usage: %s: [infile] [outfile]\n", progname);
  34.  
  35.     for (stream = 0; optind < argc; stream++, optind++)
  36.         if (stream < 2 && strcmp(argv[optind], "-") != 0)
  37.             if (freopen(argv[optind], mode[stream], f[stream]) == NULL)
  38.                 error("%s %s", PR_IO_ERR_INFILE, argv[optind]);
  39.  
  40.     if ((pr = pr_load(stdin, &colormap)) == NULL)
  41.         error(PR_IO_ERR_RASREAD);
  42.  
  43.     if (bitrestrict)
  44.         levels = calc_max(pr)+1;
  45.     else
  46.         levels = MAXLEVEL(pr->pr_depth);
  47.  
  48.     for (j = 0; j < pr->pr_size.y; j++)
  49.         for (i = 0; i < pr->pr_size.x; i++) {
  50.             val = abs(levels - pr_get(pr,i,j));
  51.             pr_put(pr, i, j, val);
  52.             }
  53.  
  54.     pr_dump(pr, stdout, &colormap, RT_STANDARD, 0);
  55. }
  56.